// pages/goodslist/index.js
import {
  GoodsListRequest
} from "../../api/goodslist.js"
Page({

  /**
   * 页面的初始数据
   */
  data: {
    tabbarlist: [
      {
        value: "综合",
        index: 0,
        select: true
      },
      {
        value: "销量",
        index: 1,
        select: false
      },
      {
        value: "价格",
        index: 2,
        select: false
      }
    ],
    goodslit: [],
    total: 0,
  },

  requestParams: {
    query: "",
    cid: "",
    pagenum: 1,
    pagesize: 10
  },

  // 接收子组件tabbar传递过来的值，并修改tabbarlist
  tabindex(e) {
    let { index } = e.detail
    let { tabbarlist } = this.data
    tabbarlist.forEach(item => {
      item.index == index ? item.select = true : item.select = false
    });
    this.setData({
      tabbarlist
    })
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.requestParams.cid = options.cid
    this.request()
  },

  // 请求数据
  request() {
    GoodsListRequest({
      url: "/goods/search",
      data: this.requestParams
    }).then(res => {
      this.setData({
        goodslit: [...this.data.goodslit, ...res.data.message.goods],
        total: res.data.message.total
      })
      // 数据请求结束后关闭下拉刷新
      wx.stopPullDownRefresh();
    })

  },
  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {
    var maxpage = Math.ceil(this.data.total / this.requestParams.pagesize);
    if (this.requestParams.pagenum >= maxpage) {
      wx.showToast({
        title: '没有更多数据',
      });
    } else {
      this.requestParams.pagenum++;
      this.request();
    }
  },
  /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
  onPullDownRefresh: function () {
    this.requestParams.pagenum = 1
    this.setData({
      goodslit: []
    })
    this.request();
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },


  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})